草庐IT

c++ - 包装第 3 方 DLL

全部标签

C++ Windows MFC 并发 : Get thread to wait until particular state achieved

在WindowsMFC并发上,我如何告诉我的当前线程等待直到达到特定状态?目前我能想到的唯一方法是执行周期性sleep并检查状态——当我们处于预期状态时,然后继续。有更好的方法吗?BOOLachieved=FALSE;intmain(intargc,char**argv){//Thisfunctioncreatesanewthreadandmodifiesthe'achieved'globalvariableatsomepointinthefuturedoSomethingOnAnotherThread();//Waitmaximum4secondsfor'achieved'tobeT

c - 在 C 中初始化地址为零的变量

这可能是一个非常基本的问题。我知道有一个C约定将空指针的值设置为零。您是否有可能在Windows中为新变量分配空间,而分配空间的地址恰好为零?如果不是,通常占用该地址区域的是什么? 最佳答案 在MS-DOS上,空指针是一个相当有效的指针,并且由于操作系统在realmode中运行实际上有可能用垃圾覆盖0x0地址并破坏内核。你可以这样做:inti;unsignedchar*ptr=(unsignedchar*)0x0;for(i=0;i现代操作系统(例如Linux、Windows)在protectedmode中运行它永远不会让您直接访问

windows - Delphi静态或动态链接到windows dll

我知道在加载时隐式链接到库可以提高性能,因此我想知道在编译时以这种方式链接是否是一种好的做法,从而增加可执行文件的大小(诚然这只是边际)相比在运行时显式链接。我的问题是,当针对位于System32中的MicrosoftWindowsdll文件进行链接时,在加载时进行链接是否“更好”,因为您几乎可以确定库将存在或遵循显式方法?使用的语言是Delphi(pascal),相关库是WTsAPI32.dll-终端服务。编辑:正如所指出的那样-我选择的语言不正确并且已被修改。此外,由于在Unix中只有真正广泛链接到库,我关于可执行文件大小的评论可以省略,我相信当时我实际上指的是静态链接,它将库代码

c - 如何在 ring0(内核模式)中使用 winapi 函数?

我无法在驱动程序中调用FileTimeToSystemTime()方法。错误是:错误C4013:“FileTimeToSystemTime”未定义;假设extern返回int。我也不能包含windows.h,因为我已经包含了ntddk.h,它会导致很多错误。如果我在header中将其声明为BOOLFileTimeToSystemTime(INconstPFILETIME,OUTPSYSTEMTIME);我会收到下一个错误:错误C2061:语法错误:标识符“FileTimeToSystemTime”错误C2059:语法错误:';'错误C2059:语法错误:“类型”错误C4013:“Fil

c++ - 构建一个不依赖 dll 的 C++ 二进制文件

我写了一些C++代码。我把它发给了我的friend,他不是开发人员。在Windows7上,他收到错误消息“程序无法启动,因为缺少msvcr120.dll”如何构建它才能运行?我是否需要使用MSVC2008进行编译?2005?我希望它能在vista+上运行 最佳答案 我认为您可以使用/MT代替/MD静态链接运行时库参见http://msdn.microsoft.com/en-us/library/2kzt1wy3.aspx右键单击您的项目->属性->C/C++->代码生成->将“运行时库”设置为“/MTd”用于调试,“/MT”用于发布

c++ - (C/C++) Windows 7 中的 EOF

#includevoidfcopy(FILE*from,FILE*to);intmain(){fcopy(stdin,stdout);return0;}voidfcopy(FILE*from,FILE*to){intc;while((c=getc(from))!=EOF){putc(c,to);}}当我运行这个程序时,^Z(Ctrl+z)会发生一些意外行为,我会用它来指示EOF。我输入的“hello\n”在“fcopy”中执行while循环以打印相同内容。"^Z\n"结束程序。但是如果我输入“blahblah^Zasdfasdf\n”,虽然我希望程序打印“blahblah”并终止,但它

c - 了解 C 中的缓冲

我真的很难理解缓冲的深度,尤其是在C编程中,我在这个主题上搜索了很长时间,但直到现在还没有找到令人满意的东西。我会更具体一点:我确实理解它背后的概念(即不同硬件设备的操作协调和最小化这些设备的速度差异)但我希望能更全面地解释这些和其他潜在的缓冲原因(我的意思是完整的)越长越深越好)给出一些具体的例子来说明缓冲是如何在I/O流中实现的。其他问题是我注意到我的程序没有遵循缓冲区刷新中的一些规则,这听起来很奇怪,就像下面的简单片段:#includeintmain(void){FILE*fp=fopen("hallo.txt","w");fputc('A',fp);getchar();fput

c - 如何区分16位MZ和32位MZ

我需要区分32位PE和16位DOSMZ。正确的做法是什么?我可以使用启发式方法,例如查找PEheader,但我觉得它不一定是确定性的 最佳答案 所有DOS风格的可执行文件都有一个“MZ”作为前两个字节。要识别MSDOS可执行文件与众多其他变体,最好的办法似乎是读取文件中偏移量0x0018处重定位表的位置,如果它大于0x0040(进入文件),则它不仅仅是普通的DOS.为了明确地将可执行文件标识为“PE”可执行文件,在文件中的偏移量0x003C处有一个指针。这是文件中的偏移量,将包含字节“PE”和两个空值。其他MSDOS的“MZ”变体将

c++ - 在运行时在 v110 可执行文件中使用 v90 COM dll 是否安全?

在使用v110编译器构建的可执行文件中使用使用v90编译器构建的COMdll是否安全?可执行文件在运行时通过COM接口(interface)使用v90dll(它不是#imported)。可执行文件是根据dll的tlb构建的。两者都静态链接到MFC,并且都使用/MT版本的运行时库。我的理解是这是可能的,但并不安全。由于存在使用注意事项(即内存分配不同,因此不能在dll中分配对象并在可执行文件中删除对象,因为这会导致意外行为)。有人可以为我澄清一下吗? 最佳答案 是的,它是安全的。前提是您遵守COM规则。COM规则是ABI1规则,包括与

.net - 线程是否可以在临界区中间被抢占?

是否可以通过在Windows中禁用中断来实现临界区锁定?如果是这种情况,则当线程处于临界区中间时,它不能被抢占。但如果是这种情况,即如果一个线程在执行关键部分时不能被抢占,那将使得脉冲监视器的整个点不如如果即使线程处于关键部分的中间,也可能会要求线程撤出CPU。所以,我真正的问题是:在Windows中如何实现监视器?线程处于临界区中间时是否可以被抢占? 最佳答案 Windows的设计使得线程,即使在内核模式下运行,arealwayspreemptibleandalwaysinterruptible.所以临界区肯定不是通过禁止中断来实